<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="../application/vue.js"></script>
</head>
<body>
    <div id="app">
        <p>msg:{{msg}}</p>
        <input type="text" v-model="msg">
        <hr>
        <!-- <comp-a :msg="msg" @update:msg="sentMsg"></comp-a> -->
        <comp-a :msg="msg" ></comp-a>
    </div>
    <template id="child">
        <div >
            <p>msg::{{msg}}</p>
            <input type="text" v-model="msg">
            <input type="text" :value="msg" @input="sentMsg($event.target.value)">
            <input type="text" v-model="getMsg">
        </div>
    </template>
</body>
<script>
    new Vue({
        el:"#app",
        components:{
            compA:{
                template:"#child",
                props:["msg"],
                computed:{
                    // getMsg(){
                    //     return this.msg;
                    // }
                    getMsg:{
                        get(){
                            return this.msg;
                        },
                        set(nv){
                            this.$root.$emit("update:msg",nv);
                        }
                    }
                },
                methods:{
                    sentMsg(a){
                        // this.$emit("update:msg",a);
                        this.$root.$emit("update:msg",a);
                    }
                }
            }
        },
        data:{
            msg:"父组件初始变量"
        },
        methods:{
            // sentMsg(a){
            //     this.msg=a;
            // }
        },
        beforeMount(){
            // this.$on("update:msg",(arg)=>{
            //     this.msg=arg;
            // })
            this.$on("update:msg",function(arg){
                this.msg=arg;
            })
        }
    })
</script>
</html>